package 删除字符串中的所有相邻重复项;

import java.util.Stack;

/**
 * @author zhengTao
 * @version 1.0
 * @description: 删除字符串中的所有相邻重复项
 * 输入："abbaca"
 * 输出："ca"
 * 解释：
 * 例如，在 "abbaca" 中，我们可以删除 "bb" 由于两字母相邻且相同，
 * 这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 "aaca"，
 * 其中又只有 "aa" 可以执行重复项删除操作，所以最后的字符串为 "ca"
 * @date 2022/10/23 15:57
 */
public class Demo1047 {
    public String removeDuplicates(String s) {
        Stack<Character>  stack=new Stack<>();
        for (int i = 0; i < s.length(); i++) {
            if(!stack.isEmpty()&&stack.peek()==s.charAt(i)) {
                stack.pop();
            }else {
                stack.push(s.charAt(i));
            }
        }
        StringBuilder stringBuilder=new StringBuilder();
        while (!stack.isEmpty()){
            stringBuilder.append(stack.pop());
        }
        return stringBuilder.reverse().toString();
    }
}
